<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box {
            position: relative;
            width: 200px;
            height: 200px;
            background-color: beige;
            margin: 0 auto;
            color: black;
        }

        span {
            display: block;
            /* 正中心 */
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            width: 20px;
            height: 20px;
            line-height: 20px;
            text-align: center;
            background-color: cornflowerblue;
        }
    </style>
</head>

<body>
    <div class="box">

    </div>
    <script>
        // 防抖:
        // 单位时间内，频繁触发事件，只执行最后一次。
        // 节流:
        // 单位时间内，频繁触发事件，只执行一次。



        let box = document.querySelector('.box')
        let i = 0
        function mo() {
            box.innerHTML = `<span>${i++}</span>`
        }
        //手写节流函数
        // 核心是利用定时器setTimeout来实现
        // 1.声明一个定时器,return返回匿名函数
        // 2.事件触发先判断是否有定时器，如果有定时器就不开启新定时器
        // 3.如果没有定时器就开启定时器，存变量里
        // 3.1定时器里面调用要执行的函数
        // 3.2定时器里面要把定时器清空

        function jieliu(fu, time) {
            let setjl = null
            return function () {
                if (!setjl) {
                    setjl = setTimeout(function () {
                        mo()
                        setjl = null
                    }, time)
                }
            }
        }
        box.addEventListener('mousemove', jieliu(mo, 1000))
    </script>
</body>

</html>